import { Link , useNavigate } from 'react-router-dom'
import { Card, Breadcrumb, Form, Button, Radio, DatePicker, Select,Popconfirm } from 'antd'
import locale from 'antd/es/date-picker/locale/zh_CN'
// 引入汉化包 时间选择器显示中文
// 导入资源
import { Table, Tag, Space } from 'antd'
import { EditOutlined, DeleteOutlined } from '@ant-design/icons'
import img404 from '@/assets/error.png'
import { useChannel } from '@/hooks/useChannel'
import { useEffect, useState } from 'react'
import { getArticleListAPI ,delArticleAPI} from '@/apis/article' 

const { Option } = Select
const { RangePicker } = DatePicker
const Article = () => {
    const { channelList } = useChannel()
    const navigate = useNavigate()
    // 准备列表数据
    // 定义状态枚举
    const status = {
        1: <Tag color='warning'>待审核</Tag>,
        2: <Tag color='green'>审核通过</Tag>
    }
    const columns = [
        {
            title: '封面',
            dataIndex: 'cover',
            width: 120,
            render: cover => {
                return <img src={cover.images[0] || img404} width={80} height={60} alt="" />
            }
        },
        {
            title: '标题',
            dataIndex: 'title',
            width: 220
        },
        {
            title: '状态',
            // 此处的dataIndex代表的是传过来的数据data中的status
            dataIndex: 'status',
            // render是用于二次处理用的
            // 如果data == 1 => 显示待审核 如果为2 显示 审核通过
            // render: data => data === 1 ? <Tag color='warning'>待审核</Tag> : <Tag color='green'>审核通过</Tag>
            render: data => status[data]
        },
        {
            title: '发布时间',
            dataIndex: 'pubdate'
        },
        {
            title: '阅读数',
            dataIndex: 'read_count'
        },
        {
            title: '评论数',
            dataIndex: 'comment_count'
        },
        {
            title: '点赞数',
            dataIndex: 'like_count'
        },
        {
            title: '操作',
            render: data => {
                return (
                    <Space size="middle">
                        <Button type="primary" shape="circle" icon={<EditOutlined />} onClick={() => navigate(`/publish?id=${data.id}`)}/>
                        <Popconfirm
                            title="删除文章"
                            description="确认要删除当前文章吗?"
                            // 将data参数传入
                            onConfirm={() => onConfirm(data)}
                            okText="Yes"
                            cancelText="No"
                        >
                            <Button
                                type="primary"
                                danger
                                shape="circle"
                                icon={<DeleteOutlined />}

                            />
                        </Popconfirm>
                    </Space>
                )
            }
        }
    ]
    // 准备表格body数据
    // 筛选功能
    // 1.准备参数
    const [reqData, setReqData] = useState({
        status: '',
        channel_id: '',
        begin_pubdate: '',
        end_pubdate: '',
        page: '1',
        per_page: '4',
    })

    // 获取文章列表
    const [list, setList] = useState([])
    const [count, setCount] = useState(0)
    useEffect(() => {
        async function getList() {
            const res = await getArticleListAPI(reqData)
            setList(res.data.data.results)
            // console.log(res.data.data.results);
            setCount(res.data.data.total_count)
        }
        getList()
    }, [reqData])

    const data = list


    // 2.获取当前的筛选数据
    const onFinish = (formValue) => {
        // 3. 把表单收集到数据放到参数中
        setReqData({
            ...reqData,
            status: formValue.status,
            channel_id: formValue.channel_id,
            begin_pubdate: formValue.date[0].format('YYYY-MM-DD'),
            end_pubdate: formValue.date[1].format('YYYY-MM-DD')
        })
        // 4.重新拉取文章列表 + 渲染table逻辑重复的 - 复用
        //reqData依赖项发生变化 重复执行副作用函数
    }
    // 分页
    // 声明回调函数
    const onPageChange = (page) => {
        // 重新渲染文章列表
        // console.log(page);
        // reqData 一旦发生变化就会引起重新渲染~
        setReqData({
            ...reqData,
            page
        })
    }
    // 删除
     const onConfirm = async (data) => {
        // console.log('删除点击了',data);
        await delArticleAPI(data.id)
        // console.log(data.id);
        setReqData({
            ...reqData
        })

        
     }
    return (
        <div>
            <Card
                title={
                    <Breadcrumb items={[
                        { title: <Link to={'/'}>首页</Link> },
                        { title: '文章列表' },
                    ]} />
                }
                style={{ marginBottom: 20 }}
            >
                <Form initialValues={{ status: '' }} onFinish={onFinish}>
                    <Form.Item label="状态" name="status">
                        <Radio.Group>
                            <Radio value={''}>全部</Radio>
                            <Radio value={0}>草稿</Radio>
                            <Radio value={2}>审核通过</Radio>
                        </Radio.Group>
                    </Form.Item>

                    <Form.Item label="频道" name="channel_id">
                        <Select
                            placeholder="请选择文章频道"
                            defaultValue="lucy"
                            style={{ width: 120 }}
                        >
                            {channelList.map(item => <Option key={item.id} value={item.id}>{item.name}</Option>)}
                        </Select>
                    </Form.Item>

                    <Form.Item label="日期" name="date">
                        {/* 传入locale属性 控制中文显示*/}
                        <RangePicker locale={locale}></RangePicker>
                    </Form.Item>

                    <Form.Item>
                        <Button type="primary" htmlType="submit" style={{ marginLeft: 40 }}>
                            筛选
                        </Button>
                    </Form.Item>
                </Form>
            </Card>
            <Card title={`根据筛选条件共查询到 ${count} 条结果：`}>
                {/* columns是用来渲染列的 data是用来渲染列表数据的 */}
                <Table rowKey="id" columns={columns} dataSource={data} pagination={{ total: count, pageSize: reqData.per_page, onChange: onPageChange }} />
            </Card>
        </div>
    )
}

export default Article